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SYNCHRONIZATION OF AUTHENTICATION CIPHERING OFFSET 

BACKGROUND 

The present invention relates to communications systems, and more 
particularly to synchronization between communicating entities that experience 
5 non-controllable delays in an interface between a real-time and a non-realtime 
layer. 

As the number of commonly used computerized, portable devices 
increases, there is an increased need for communication between these devices. 
As a result, many standards for providing communication between such devices 
10 have been implemented in various data sharing schemes and communication 
systems. 

An example of one such system is called Bluetooth, which has recently 
been introduced to provide pervasive connectivity especially between portable 
devices like mobile phones, laptops, personal digital assistants (PDAs), and other 

15 nomadic devices. It should be understood that Bluetooth is one of many systems 
within which the present invention may be employed. Therefore, although some 
examples of problems to be solved by the present invention will be provided 
within the context of Bluetooth, those skilled in the art will realize that these 
examples are merely illustrative, and that the present invention may be employed 

20 to solve similar problems within other similar systems. 

The Bluetooth system applies frequency hopping to enable the construction 
of low-power, low-cost radios with a small footprint. The system supports both 
data and voice. The latter is optimized by applying fast frequency hopping (FH) 
in combination with a robust voice coding. The fast frequency hopping has a 

25 nominal rate of 1600 hops per second (hops/s), corresponding to 800 hops/s in 
each direction, through the entire 2.4 GHz ISM band, which is 80 MHZ wide. 

Devices based on the Bluetooth system concept can create so called 
piconets, which comprise a master device and one or more slave devices 
connected via the FH piconet channel. The FH sequence used for the piconet 
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channel is completely determined by the address or identity of the device acting as 
the master. The system clock of the master device determines the phase in the 
hopping sequence (i.e. , the designation of which one of the possible hops in the 
sequence is the "current" hop). In the Bluetooth system, each device has a free- 
5 running system clock. Each of the slave devices adds a corresponding time offset 
to its clock that enables it to become aligned with the clock of the master device. 
By using the master address to select the proper hopping sequence and by using 
the time offset to align to the master clock, each slave device keeps in hop 
synchrony to the master device; that is, master and slave devices remain in contact 

10 by hopping synchronously to the same hop frequency or hop carrier. For more 
details, reference is made to U.S. Patent Application No. 08/932,911, filed on 
Sept. 18, 1997 in the name of J.C. Haartsen and entitled "Frequency Hopping 
Piconets in an Uncoordinated Wireless Multi-user System," which is hereby 
incorporated herein by reference in its entirety. Also incorporated by reference 

15 herein in its entirety is the Specification of the Bluetooth System, version 1.0A, 
which is available via the Internet at the following Universal Resource Locator 
(URL): http://www.bluetooth.com. 

As set forth in the Specification of the Bluetooth System, two mechanisms 
have been included to facilitate low level security functionality: authentication and 

20 encryption. The authentication procedure is initiated whenever one unit (denoted 
herein as "unit A 5 ') wants some proof of the claimed identity of another unit 
(denoted herein as "unit B") to which unit A has a Bluetooth radio connection. 
Once the claimed identities of the involved units have been verified (either single- 
sided or, if the application that is running over the link so requires, mutually), the 

25 units can start using the link for traffic. A prerequisite for a successful 

authentication is that both units know a common secret, namely, the link key. 

The authentication procedure in Bluetooth follows a challenge-response 
scheme. In short, the verifier generates a challenge in the form of a random 
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number (denoted herein as AU RAND), that is sent to the claimant. Upon 
receiving this challenge, the claimant computes a signed response (denoted herein 
as SRES), that is sent back to the verifier. The verifier can independently 
compute what the response ought to be (denoted herein as SRES'), given the 
5 challenge and the shared secret link key used by the two Bluetooth units. If the 
received SRES equals the computed SRES', the authentication is considered 
successful. If, on the other hand, these two numbers differ, the claimant failed to 
prove its identity. This challenge-response scheme need not be limited to the 
Bluetooth system, however, and can be employed in a variety of communications 

10 systems requiring authentication. In such systems, a challenge-response format 

may be used with similar or identical values being communicated between various 
units of the system. 

If the application at some point requires data confidentiality, the units may 
switch encryption on. This process also requires a common secret: the 

15 encryption key. The encryption key is different from, but derived from the link 
key. Usually, the authentication is done at the time of connection setup. Even if 
it is possible to repeat the authentication process at later times, it is not 
mandatory. Therefore, a long time may have elapsed since the authentication was 
done and the encryption is switched on. Consequently there is no real guarantee 

20 that none of the units has been replaced by a malicious user during this time 
(unless the authentication process is frequently repeated). 

Hopefully, as soon as encryption is switched on, a fraudulent unit is 
immediately disclosed. This is because any such unit should not be in possession 
of the secret link key that is used by the devices originally involved in the link. 

25 Therefore, the unit is also unable to derive the encryption key. To further 

increase difficulties for a malicious unit, the creation of the encryption key is 
dependant not only on the link key, but also on a number that is denoted 
"Authentication Ciphering Offset" (ACO). The ACO is a number that is created 
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for every call of the function that generates the SRES. If two units switch on 
encryption with different ACOs, their respective generated encryption key will 
differ even if they use the same link key. 

The computation of SRES and ACO is defined by an algorithm that is 
5 denoted E±. More formally, 

E x : {0, l} 128 x {0, l} 128 x {0, l} 48 - {0, l} 32 x {0, l} 96 , (1) 
(K, AURAND, BDADDR) ^ (SRES, X) 

where the notation {0, I} 1 denotes a binary number of length i, K is the 128-bit 
link key, AURAND is a 128-bit challenge issued by the verifier, BD ADDR is 

10 the 48-bit Bluetooth device address of the claimant, SRES is a 32-bit signed 

response, and X is a 96-bit number that is computed at the same time as SRES. It 
is further noted that the operator " x " does not necessarily represent 
multiplication, but rather is used to indicate that the parameters to the left of the 
arrow are applied together in an operation that generates the two parameters to the 

15 right of the arrow. This function is defined in Chapter 14 of the Specification of 
the Bluetooth System . It will be understood, however, by those skilled in the art 
that other suitable algorithms may be employed, either in the Bluetooth system, or 
other communication systems. 

Currently, for each call of each device updates its value of ACO. 

20 Thus, in conventional systems, 

ACO = X. (2) 

A problem arises in current authentication schemes from the difficulty in 
synchronizing ACO values. For example, problems may arise from the fact that 
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the current Bluetooth baseband specification says that the units shall always use 
the latest generated ACO, which may be difficult to ascertain. There are two 
logical levels of interest to this problem. First, there may be an unknown delay in 
communications between units. Second, there may be difficulty in determining 
5 which transmissions are the latest due to simultaneous or nearly simultaneous 
transmissions. 

FIG. 1 illustrates one possible communications scheme in which 
authentication and/or encryption may be required between two units. FIG. 1 may 
relate to the Bluetooth system, or to any other suitable communications system in 

10 which authentication and/or encryption are required. As illustrated in FIG. 1, 
within each unit a Link Manager (LM) 101 generates LM messages, and a 
Baseband (BB) transmitter 103 executes the actual encoding and transmission of 
the messages to a BB receiver 105 in the other unit. Likewise, a BB receiver 105 
within each unit decodes received bit-streams, and passes these on to the link 

15 manager 101 in the layer above. The link manager 101 handles the actual 
interpretation of the messages. 

Unfortunately, due to implementation issues, there may be an unknown 
delay between the time at which the link manager 101 generates a message and the 
time at which the BB transmitter 103 transmits that message. The same is true at 

20 the receiver side as well: the BB receiver 105 receives a message which is 

interpreted and handled by the link manager 101 with some unpredictable delay. 
The above-described situation is true for all sorts of LM messages, including 
authentication requests within various authentication schemes. 

There are several possible reasons for the delay. Clearly, internal 

25 hardware design (such as buffering) and the offered traffic load affect this delay. 
Moreover, the characteristics of the radio channel (such as the interference 
situation and the signal-to-noise ratio) have an impact. For instance, unit A may 
have a backlog of messages that have not been delivered yet to unit B because of a 
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bad radio channel. If the link manager 101 in unit A generates a new message, it 
will be placed in a transmission queue, but it will not be transmitted until all 
backlogged messages have been sent. 

A problem may arise if both units start requesting an authentication of the 
5 other side simultaneously (or, to be more precise, within a "short" interval that 
depends on the actual delay). This is because there is no way to know the length 
of the delay from the point in time at which an event is generated at one side until 
the subsequent point in time that the event is registered at the other side. Clearly, 
in this situation each side needs to call its encryption key generation algorithm E 1 
10 two times: once for the request generated by the unit itself, and a second time to 
generate a response to the request that was received from the other side. As will 
be illustrated by way of example, due to different delays, the last call at side A 
may differ from the last call at side B. Consequently, units A and B will generate 
different encryption keys when encryption is switched on, resulting in their not 
15 being able to communicate intelligibly with each other. 

FIG. 2 illustrates a case in which both sides end up with the same ACO, 
resulting in a situation in which they can communicate with one another even after 
encryption is turned on. The vertical lines represent the time scale of the link 
manager 101 in each of the units A and B, with time advancing in the downward 
20 direction. At step 201, unit A wants to verify the identity of unit B, and so 

generates a challenge, denoted AU_RAND A . The challenge is transmitted to unit 
B. At step 203, unit B receives the challenge from unit A, and responds by 
calling E x to generate the two parameters SRES A and ACO A . (The subscript A in 
the various parameters indicates that they are associated with unit A's challenge.) 
25 Unit B's generated response parameter, SRES A , is then transmitted back to unit 
A. 

At step 205, unit A receives unit B's response parameter, SRES A , and 
responds by calling E 1 to calculate expected response parameters SRES' A and 



ACO A . Unit A then can compare the expected signed response, SRES' A with the 
actual signed response, SRES A , to determine whether unit B is authentic. 

At step 207, unit B wants to verify the identity of unit A, and so generates 
a challenge, denoted AU_RAND B . The challenge is transmitted to unit A. At 
step 209, unit A receives the challenge from unit B, and responds by calling E x to 
generate the two parameters SRES B and ACO B . (The subscript B in the various 
parameters indicates that they are associated with unit B's challenge.) Unit A's 
generated response parameter, SRES B , is then transmitted back to unit B. 

At step 211, unit B receives unit A's response parameter, SRES B , and 
responds by calling E x to calculate expected response parameters SRES' B and 
ACO B . Unit B then can compare the expected signed response, SRES' B with the 
actual signed response, SRES B , to determine whether unit A is authentic. 

Sometime later, the units decide to utilize encryption in their 
communication with one another. Accordingly, at step 213, unit A turns on 
encryption, using its most recently generated value of ACO to generate the 
encryption key that it will use. Similarly, at step 215, unit B turns on encryption, 
using its most recently generated value of ACO to generate the encryption key that 
it will use. In this case, the most recently generated value of ACO at both unit A 
and unit B is ACO B . Consequently, both units will generate the same encryption 
key, and will be able to continue communicating with one another. 

Turning now to FIG. 3, this illustrates an example in which delays in 
transmission cause the two units A and B to end up with different ACO values, 
thereby making it impossible to communicate after encryption is turned on. More 
specifically, at step 301, unit A wants to verify the identity of unit B, and so 
generates a challenge, denoted AU_RAND A . The challenge is transmitted to unit 
B. However at step 303, which is prior to receipt of the challenge from unit A, 
unit B also decides to verify the identity of unit A, and so generates its own 
challenge, denoted AU_RAND B . 



-8- 



At step 305, unit A receives unit B's challenge and responds by calling E { 
to generate the two parameters SRES B and ACO B . (The subscript B in the 
various parameters indicates that they are associated with unit B's challenge.) 
Unit A's generated response parameter, SRES B , is then transmitted back to unit B. 

5 Similarly, at step 307 unit B receives unit A's challenge (transmitted at 

step 301) and responds by calling E x to generate the two parameters SRES A and 
ACO A . (The subscript A in the various parameters indicates that they are 
associated with unit A's challenge.) Unit B's generated response parameter, 
SRES A , is then transmitted back to unit A. 

10 At step 309, unit B receives unit A's response parameter, SRES B , and 

responds by calling E x to calculate expected response parameters SRES' B and 
ACO B . Unit B then can compare the expected signed response, SRES' B with the 
actual signed response, SRES B , to determine whether unit A is authentic. 
Similarly, at step 311, unit A receives unit B's response parameter, 

15 SRES A , and responds by calling E x to calculate expected response parameters 
SRES' A and ACO A . Unit A then can compare the expected signed response, 
SRES' A with the actual signed response, SRES A , to determine whether unit B is 
authentic. 

Sometime later, the units decide to utilize encryption in their 
20 communication with one another. Accordingly, at step 313, unit A turns on 
encryption, using its most recently generated value of ACO to generate the 
encryption key that it will use. Similarly, at step 315, unit B turns on encryption, 
using its most recently generated value of ACO to generate the encryption key that 
it will use. In this case, the most recently generated value of ACO at unit A is 
25 ACO A , whereas the most recently generated value of ACO at unit B is ACO B . 
Consequently, the units A and B will generate different encryption keys, thereby 
making it impossible to continue communicating with one another. 
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The problem depicted in FIG. 3 can be averted by using special rules. For 

example, in the current version of the Bluetooth baseband specification, a solution 

is provided for by using the following rule: 

In case of mutual authentication, the ACO value from the second 
5 authentication is retained. However, in some situations an 

authentication event may be initiated simultaneously in both 
devices. When this happens, there is no way of telling which is the 
first and which is the second event. Then, both units shall use the 
ACO resulting from the challenge generated in the master unit. 

10 A second unit (unit B) can determine that an authentication event has been 

generated simultaneously, or nearly simultaneously, in a first unit (unit A) when a 
challenge is received from unit A, but a response to a previously sent challenge 
originating in unit B is expected. In this case, the authentication event initiated by 
unit B is considered to be open. An authentication event is considered to be open 

15 by the originating side until the response has been received. The event is closed 
when the response has been received and processed by the originating side. 
Therefore, in a situation similar to the one in FIG. 3, using the Bluetooth rule 
stated above, unit B would observe that it had received an authentication request at 
step 307 rather than the expected response to the previously sent challenge, sent at 

20 step 303. Therefore, because the request initiated at unit B in step 303 is 

considered open, ACO A resulting from the challenge generated by the master unit 
A at step 301 will be used by unit B, rather than ACO B . Likewise, unit A would 
also receive an authentication request (step 305) while its authentication event 
initiated at step 301 was open and would therefore also use ACO A according to 

25 the same rule. By use of this rule, devices communicating in a Bluetooth system 
would therefore avert the problem shown in FIG. 3. 

Turning now to FIG. 4, this illustrates an example in which delays in a 
Bluetooth system, either in transmission or processing, cause the two units A and 
B to end up with different ACO values, thereby making it impossible to 
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communicate after encryption is turned on. Thus, despite the rule which 
facilitates communication in a situation like the one depicted in FIG. 3, delays 
could cause difficulty in communication in a Bluetooth system that uses the same 
rule. More specifically, at step 401, unit A wants to verify the identity of unit B, 

5 and so generates a challenge, denoted AU_RAND A . The challenge is transmitted 
to unit B. However at step 403, which is prior to receipt of the challenge from 
unit A, unit B also decides to verify the identity of unit A, and so generates its 
own challenge, denoted AU RAND B . 

At step 405, unit B receives unit A's challenge (transmitted at step 401) 

10 and responds by calling E x to generate the two parameters SRES A and ACO A . 

(The subscript A in the various parameters indicates that they are associated with 
unit A's challenge.) Unit B's generated response parameter, SRES A , is then 
transmitted back to unit A. Unit B generates this response knowing that its 
authentication request is open, and it will therefore use the ACO value generated 

15 by the master, unit A, according to the Bluetooth specification rule. 

At step 407, unit A receives unit B's response parameter, SRES A , at a time 
denoted t A , and responds by calling E x to calculate expected response parameters 
SRES' A and ACO A . Unit A then can compare the expected signed response, 
SRES' A with the actual signed response, SRES A , to determine whether unit B is 

20 authentic. Unit A performs this calculation without knowing that nearly 

simultaneous verification events have taken place because unit B's request is 
received after its response to unit A's request, when unit A's authentication event 
is already closed. 

At step 409, unit A receives unit B's challenge and responds by calling E 1 
25 to generate the two parameters SRES B and ACO B . (The subscript B in the 
various parameters indicates that they are associated with unit B's challenge.) 
Unit A's generated response parameter, SRES B , is then transmitted back to unit B. 
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At step 411, unit B receives unit A's response parameter, SRES B , at a time 
denoted t B . However, rather than calling E x to calculate expected response 
parameters SRES' B and ACO B , unit B calculates SRES' B but retains ACO A from 
the master unit A in accordance with the rule of the Bluetooth specification. 

5 The problem illustrated in FIG. 4 arises because the authentication request 

from unit B AUJRAND B , generated at step 403 by unit B, is received by unit A 
(step 409) after receipt of the signed response SRES A , which is generated at step 
405 by unit B and received at time t A at step 407 by unit A. Consequently, unit A 
does not know that the two authentication requests have been generated nearly 

10 simultaneously because unit A's authentication request event is closed at time t A 
before the authentication request generated by unit B is received. Therefore, unit 
A does not apply the Bluetooth specification rule that requires both units to use the 
master's ACO value, but instead uses ACO B . However, unit B receives unit A's 
authentication request, which is generated by unit A at step 401 and received by 

15 unit B at step 405 after unit B has generated its authentication request at step 403. 
Because the authentication request generated by unit A is received after the 
authentication request generated by unit B but before a response is received from 
unit A at step 411, unit B realizes that the two authentication requests are nearly 
simultaneous, and applies the Bluetooth specification rule which requires unit B to 

20 use the ACO value of the master unit, or ACO A . 

As a consequence of this time delay of unit B's authentication request, 
when the two devices later turn on encryption, unit A utilizes ACO B , as shown at 
step 413, and unit B utilizes ACO A , as shown at step 415. As a consequence, 
once encryption is turned on by the two units using different ACO values, 

25 communication will be impossible. 

In the examples described above, it was assumed that each unit generates 
its expected signed response, SRES\ only after receiving the actual signed 
response from the other unit. However, this is not a requirement, as a unit could, 
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for example, generate its expected signed result (SRES') at the same time that it 
generates the challenge, AUJRAND. Such a determination of when an SRES' is 
generated may be dependent on the system in which it is being implemented. The 
Specification of the Bluetooth System , for example, leaves the particular 

5 implementation up to the developer. Because there is no requirement that it be 
done one way or the other, it is possible that one unit, made by a first 
manufacturer, will compute SRES 5 at the same time that it generates the challenge, 
while the other unit, made by a different manufacturer, will generate its SRES' 
only upon receiving the signed response from the other side. In such a scenario, 

10 the two units could again end up with different most-recently-generated values of 
ACO, which makes it impossible for them to generate the same encryption key 
when encryption is turned on. 

There is therefore, a need for a system that avoids the problems associated 
with the prior art, such as the possibility of ending up with different ACO values, 

15 and thereby using incompatible encryption. 

SUMMARY 

It should be emphasized that the terms "comprises" and "comprising", 
when used in this specification, are taken to specify the presence of stated 
features, integers, steps or components; but the use of these terms does not 

20 preclude the presence or addition of one or more other features, integers, steps, 
components or groups thereof. 

The foregoing and other objects are achieved by the present invention, 
which may be used in a communication system. One such system is the Bluetooth 
system. In accordance with an aspect of the invention, an authentication ciphering 

25 offset (ACO) is generated as a function of one or more parameters, wherein at 

least one of the one or more parameters is derived from earlier-computed values of 
the ACO. This enables each device to avoid generating an ACO value that is out 
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of synchronization with a counterpart ACO value generated in another 
communication device thereby avoiding problems caused by uncontrollable delays 
associated with the prior art systems, for example. 

BRIEF DESCRIPTION OF THE DRAWINGS 

5 The objects and advantages of the invention will be understood by reading 

the following detailed description in conjunction with the drawings in which: 
FIG. 1 is a block diagram of two units, each having a link manager, a 
baseband transmitter and a baseband receiver; 

FIG. 2 is a timing diagram of authentication signaling in an instance when 
10 both units end up with a same value of ACO; 

FIG. 3 is a timing diagram of authentication signaling in the prior art in an 
instance when both units end up with different values of ACO; 

FIG. 4 is a timing diagram of authentication signaling in the prior art in an 
instance when both units have the potential of using different values of ACO 
15 because of a delayed signal; 

FIG. 5 is a flow diagram of the computation of an ACO value in 
accordance with one embodiment of the present invention; 

FIG. 6 is a timing diagram of how the present invention may be 
implemented in a communications system; and 
20 FIG. 7 is a timing diagram of how the present invention may be 

implemented in a communication system employing certain rules. 

DETAILED DESCRIPTION 

The various aspects of the invention will now be described in detail in 
connection with a number of exemplary embodiments and with respect to the 
25 figures, in which like parts are identified with the same reference characters. To 
facilitate an understanding of the invention, many aspects of the invention are 
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described in terms of sequences of actions to be performed by elements of a 
computer system. It will be recognized that in each of the embodiments, the 
various actions could be performed by specialized circuits (e.g., discrete logic 
gates interconnected to perform a specialized function), by program instructions 
5 being executed by one or more processors, or by a combination of both. 

Moreover, the invention can additionally be considered to be embodied entirely 
within any form of computer readable storage medium having stored therein an 
appropriate set of computer instructions that would cause a processor to carry out 
the techniques described herein. Thus, the various aspects of the invention may 

10 be embodied in many different forms, and all such forms are contemplated to be 
within the scope of the invention. For each of the various aspects of the 
invention, any such form of embodiment may be referred to herein as "logic 
configured to" perform a described action. 

The problems associated with the prior art can be overcome by using a new 

15 function that generates the "Authentication Ciphering Offset" (ACO) as a function 
of all earlier-computed values of ACO, in addition to other possible parameters. 

As illustrated in FIG. 5, a triggering event (step 501) triggers a particular 
device or communications unit to calculate an ACO as a function of pre- 
determined parameters (step 503), at least one of which is derived from earlier 

20 computed values of the ACO. The triggering event 501 may be any one of a 
number of internal or external triggering events. For example, an external 
triggering event may be an authentication request, or a signed response received 
from another device. Examples of internal triggering events may include certain 
timed events, and the like. As to generating a new ACO value, any commutative 

25 binary function is sufficient for creating an ACO value based upon previous 
values, which is not dependent upon order. 

In an exemplary embodiment, each unit keeps a running sum (bitwise 
modulo-2) of the ACO values, and combines a most recent value of ACO with a 
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presently generated value of X (produced by calling E 2 ) . Thus, after the k call of 
Ei, the ACO becomes: 

k 

ACO k = X k eACO k _ 1 = 5>. , (3) 

I =1 

where, in this exemplary embodiment, the sum is bitwise modulo-2. This sum 
may advantageously be generated by employing an exclusive-OR (XOR) function. 
5 The value of X k may be computed in the conventional way, using the function 
denoted E± . 

Since the order of the elements in the sum is irrelevant, the two units A 
and B will have identical ACO values whenever the following result is satisfied: 
{x/ A) |i = l..Jfc} = {x/ B) |* = l...k}. As a result, situations similar to the 
10 example described in FIG. 3 and FIG. 4 will not cause any problem when 
encryption is switched on. 

Techniques other than summing all of the previous ACO values using XOR 
operations may also be employed. For example, any variety of functions using 
previous values of ACO may be employed to maintain the same ACO in both 
15 units, so long as the selected function or functions satisfy the commutative law. 
Simple boolean functions such as logical AND, NAND, OR, NOR, addition, 
subtraction, and multiplication functions could be used. One might, for example, 
use any commutative binary operations between X k and ACO^, shown in 
Equation 3. Additionally, more complex functions, such as convolution sums, for 
20 example, could also be used. 

It should be noted, however, that simple binary functions other than XOR 
functions may not be desirable as they may create an ACO that, after many 
iterations, tends toward a specific result, thereby generating an ACO that may be 
predictable. Furthermore, more complex functions may not be desirable as they 
25 may increase the computational complexity of the algorithm significantly. 
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However, as processing speeds increase, more complicated algorithms, or 
combinations of multiple algorithms may be desirable, as they may produce ACO 
values which are more difficult to predict. 

FIG. 6 illustrates an example of how the present invention may be 
5 employed in a communications system to avoid the problem illustrated in FIG. 3. 
In FIG. 3, challenges generated by both units nearly simultaneously cause the two 
units A and B to end up with different ACO values, thereby making it impossible 
to communicate after encryption is turned on. However, in FIG. 6, using the 
present invention, each new value of ACO is calculated using the previous ACO 
10 values, thereby allowing both units to end up with the same ACO values, and 

communicate even when encryption is switched on. In the situation illustrated in 
FIG. 6, unit A and unit B begin with equivalent ACO values. Specifically, unit A 
begins with ACO m in effect, and unit B begins with ACO n (which is equivalent to 
ACO m ) in effect. 

15 At step 601, unit A wants to verify the identity of unit B, and so generates 

a challenge, denoted AU_RAND A . The challenge is transmitted to unit B. 
However, at step 603, which is prior to the receipt of the challenge from unit A, 
unit B also decides to verify the identity of unit A, and so generates its own 
challenge denoted AU_RAND B . 

20 At step 605, unit A receives unit B's challenge (transmitted at step 603) 

and responds by calling E l to generate the two parameters SRES B and ACO m+1 . 
In this example, ACO m+ 1 is derived as a function of AU RAND B and the 
previous ACO value. ACO m+ 1 may be calculated in the manner described in 
equation 3, or using other suitable commutative binary functions. Unit A's 

25 generated response parameter SRES B is then transmitted back to unit B. 

Similarly, at step 607 unit B receives unit A's challenge (transmitted at 
step 601) and responds by calling E± to generate the two parameters SRES A and 
ACO n+ 1 . ACO n+ 1 is derived as a function of AU RAND A and the previous 
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ACO value. ACO n+1 may be generating using any commutative binary 
algorithm, including the one shown in equation 3, for example. Unit B's 
generated response parameter SRES A , is then transmitted back to unit A. 

At step 609, unit B receives unit A's response parameter, SRES B , and 
5 responds by calling E 1 to calculate the expected response parameter SRES' B and 
ACO n+2 , which is a function of AU_RAND B and ACO n+ ^ Unit B then can 
compare the expected signed response, SRES' B with the actual signed response, 
SRES B , to determine whether unit A is authentic. 

Similarly, at step 611, unit A receives unit B's response parameter SRES A 

10 and responds by calling £' 1 to calculate the expected response parameters SRES' A 
and ACO m+2 > which is a function of AU_RAND A and ACO m+ 1 . Unit A then 
can compare the expected signed response SRES' A with the actual signed response 
SRES A to determine whether unit B is authentic. 

Sometime later, the units decide to utilize encryption in their 

15 communication with one another, either at a predetermined time, or by a start 
encryption request. Accordingly, at step 613, unit A turns on encryption, using 
its most recently generated value of ACO to generate the encryption key that it 
will use. Similarly, at step 615, unit B turns on encryption using its most recently 
generated value of ACO to generate the encryption key that it will use. In this 

20 case, the most recently generated ACO value for unit A is ACO m+2 > anc * the most 
recently generated ACO value for unit B is ACO n+2 . However, these values will 
be equivalent if the two units begin with equivalent values (i.e., ACO m =ACO n ), 
and if the operations performed at each generation of ACO values are 
commutative, so that the order of operation does not change the outcome of 

25 computation, such as the commutative function shown in Equation 3, for example. 
Thus, unit A and unit B will end up with equivalent ACO values, and will be able 
to communicate, even when encryption is switched on. Additionally, equivalent 
ACO values will be maintained in both units despite unknown delays or 
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simultaneous authentication requests. Thus, the present invention alleviates the 
problem described in connection with FIG. 3. 

Turning now to FIG. 7, this illustrates an example in which the problem 
described in connection with FIG. 4 has been remedied using the present 
5 invention. In FIG. 4, delays in transmission or processing of a challenge in a 
Bluetooth system cause the two units to use different ACO values, making 
communication impossible once communication is switched on. Both units begin 
the situation described in FIG. 7 using equivalent ACO values (i.e., ACO m = 
ACO n ). In FIG. 7, unit A generates an authentication request, or challenge, 

10 denoted AU_RAND A at step 701, which is then transmitted to unit B. Similarly, 
unit B transmits a request, or challenge AU RAND B at step 703, which it 
transmits to unit A. At step 705, unit B receives the challenge generated by unit 
A at step 701, and generates the signed response SRES A and ACO n+1 . ACO n+1 
is computed as a function of AU_RAND A and the previous ACO value, namely 

15 ACO n The signed response SRES A is then sent to unit A, which receives it at 
time t A shown at step 707. Unit A may then generate ACO m+ j , which is a 
function of AU_RAND A and ACO m , the previous ACO value. Unit A may also 
generate at this step an expected signed response SRES' A so that it can validate 
the authenticity of unit B. At step 709, unit A receives the challenge generated by 

20 unit B at step 703, and in response, generates a signed response SRES B , and 
calculates ACO m+2? which is a function of AU_RAND B and ACO m+1 . The 
calculation of each ACO value may be performed using any commutative binary 
operation, such as the one that is shown in equation 3, for example. Unit A then 
transmits the signed response to unit B, which receives it at time t B at step 711. 

25 Under the rules of the Bluetooth specification, unit B would retain ACO n+1 for 
future use, as both authentication requests were generated nearly simultaneously, 
which unit B is aware of due to the fact that it received a challenge from unit A 
while it had an open event (begun with the challenge generated at step 703). 
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However, in accordance with the present invention, a new value ACO n+2 ma y 
instead be calculated at time t B at step 711 as a function of AU_RAND B and 
ACO n+ 1 . This calculation may be accomplished using any commutative binary 
operation, such as the one shown in equation 3, for example. 
5 Thanks to the use of the present invention, when unit A and unit B decide 

to turn on encryption at step 713 and step 715, respectively, they will both use 
their latest ACO values, which are equivalent to one another, to determine an 
encryption key, and will therefore be able to communicate even when encryption 
is switched on. It should be noted, that the use and calculation of each ACO value 

10 by a particular unit associated with an event initiated by that unit is illustrated as 
being delayed until the event is closed in FIG. 7. However, this need not be the 
case, and the ACO value associated with that unit may be calculated at the time a 
challenge is issued by that unit, or at any other suitable time. However, potential 
problems may arise if an ACO value associated with a particular challenge event is 

15 used before the event is closed, in situations where an event is lost, not returned, 
or timed out, for example. 

The invention achieves a number of advantages over, and solves problems 
associated with, conventional approaches. It eliminates real-time requirements of 
guaranteed response time. It makes the order of ACO computations insignificant. 

20 Real-time issues with different delays between layers are less of a problem. Thus, 
the present invention allows real-time and non-real-time devices to be used in the 
same communications system, as it calculates ACO values independent of the 
order in which they are received. ACO values are also calculated independent of 
any delays in transmission, receiving, or processing. Moreover, the 

25 computational complexity of the invention is negligible. No extra storage is 
required compared to the old solution. 

The invention has been described with reference to a particular 
embodiment. However, it will be readily apparent to those skilled in the art that it 
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is possible to embody the invention in specific forms other than those of the 
preferred embodiment described above. This may be done without departing from 
the spirit of the invention. 

Furthermore, the invention has been described with respect to particular 
5 embodiments to overcome the concern that delays in communication will cause the 
ACO parameters to be unsynchronized between two units. However, the same 
principle of making a parameter a function, at least in part, of its past values can 
be applied to any system where delays cause problems with synchronization of any 
such parameters. Some such systems may include, but are not limited to, any 

10 real-time systems in which unpredictable delays may exist, and can cause potential 
problems. Some examples of such systems may include: wireless systems, such 
as mobile telephony systems, wireless paging systems, and wireless Internet 
systems; and wired systems, such as the Internet, landline telephone systems, dial- 
up networking systems, LANs, WANs, or the like. Any system that has 

15 applications at both ends of a communications link that exchange data in which 
unpredictable delays may cause problems could benefit from using the present 
invention. 

Thus, the preferred embodiment is merely illustrative and should not be 
considered restrictive in any way. The scope of the invention is given by the 
20 appended claims, rather than the preceding description, and all variations and 

equivalents which fall within the range of the claims are intended to be embraced 
therein. 
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WHAT IS CLAIMED IS: 

1 . A method of generating an authentication ciphering offset (ACO) in a 
communication device, the method comprising: 

generating the ACO as a function of one or more parameters, wherein at 
5 least one of the one or more parameters is derived from earlier-computed values of 
the ACO. 

2. The method of claim 1, wherein the step of generating the ACO as a 
function of one or more parameters comprises generating a kth value, X k from one 
or more of the parameters, and applying a commutative binary operation between 

1 0 X k and a previous value, ACO^ . 

3. The method of claim 1, wherein the step of generating the ACO as a 
function of one or more parameters comprises: 

generating a kth value of ACO as a running sum in accordance with: 

k 

ACO, = X 0 ACO, , - Ys x > 

k k k-1 ji — f i 

i =1 

wherein X t is generated as a function of the one or more parameters excluding the 
15 at least one of the one or more parameters that is derived from earlier-computed 
values of the ACO. 

4. The method of claim 3, wherein the sum is a bitwise modulo-2 sum. 

5. The method of claim 4, wherein the bitwise modulo-2 sum is performed by 
means of a bitwise exclusive-OR (XOR) operation. 



1 



-22- 

6. An apparatus for generating an authentication ciphering offset (ACO) in a 
communication device, the apparatus comprising: 

logic configured to generate the ACO as a function of one or more 
parameters, 

5 wherein at least one of the one or more parameters is derived from earlier- 

computed values of the ACO. 

7. The apparatus of claim 6, wherein the logic configured to generate the 
ACO as a function of one or more parameters comprises logic configured to 
generate a kth value, X k from one or more of the parameters, and to apply a 

10 commutative binary operation between X k and a previous value, ACO^ . 

8. The apparatus of claim 6, wherein the logic configured to generate the 
ACO as a function of one or more parameters comprises: 

logic configured to generate a kth value of ACO as a running sum in 
accordance with: 

k 

ACO, = X © ACO^ f = J2 X > 
k k k-i *—f i 

i =i 

15 wherein X t is generated as a function of the one or more parameters excluding the 
at least one of the one or more parameters that is derived from earlier-computed 
values of the ACO. 

9. The apparatus of claim 8, wherein the logic configured to generate a kth 
value of ACO comprises logic configured to perform a bitwise modulo-2 sum. 
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10. The apparatus of claim 9, wherein the logic configured to perform a 
bitwise modulo-2 sum comprises logic configured to performed a bitwise 
exclusive-OR (XOR) operation. 

1 1 . The apparatus of claim 6, wherein the communication device includes a 
real-time device. 



12. The apparatus of claim 6, wherein the communication device includes a 
non-real-time device. 
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ABSTRACT OF THE DISCLOSURE 

In a communication system, an authentication ciphering offset (ACO) is 
generated as a function of one or more parameters, wherein at least one of the one 
or more parameters is derived from earlier-computed values of the ACO. This 
enables each device to avoid generating an ACO value that is out of 
synchronization with a counterpart ACO value generated in another 
communication device. 
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